home *** CD-ROM | disk | FTP | other *** search
/ Shareware Super Platinum 8 / Shareware Super Platinum 8.iso / mac / PROGTOOL / FGL304F.ZIP;1 / EXFOR.ARJ / FGDOC / EXAMPLES / FORTRAN / 06-11.FOR < prev    next >
Encoding:
Text File  |  1994-01-24  |  1.3 KB  |  62 lines

  1. $INCLUDE: 'C:\FG\INTRFACE.FOR'
  2.  
  3.       PROGRAM MAIN
  4.  
  5.       INTEGER*2 RECTANGLES
  6.       PARAMETER (RECTANGLES=200)
  7.  
  8.       INTEGER*2 I
  9.       INTEGER*2 MINX, MAXX, MINY, MAXY
  10.       INTEGER*2 OLD_MODE
  11.       INTEGER*2 XRES, YRES
  12.       INTEGER*2 FG_AUTOMODE, FG_GETMAXX, FG_GETMAXY, FG_GETMODE
  13.       INTEGER*2 RANDOM
  14.  
  15.       OLD_MODE = FG_GETMODE()
  16.       CALL FG_SETMODE(FG_AUTOMODE())
  17.  
  18.       XRES = FG_GETMAXX()
  19.       YRES = FG_GETMAXY()
  20.  
  21.       DO 10 I = 1,RECTANGLES
  22.          MINX = RANDOM(0,XRES)
  23.          MAXX = RANDOM(0,XRES)
  24.          MINY = RANDOM(0,YRES)
  25.          MAXY = RANDOM(0,YRES)
  26.          IF (MINX .GT. MAXX) CALL SWAP(MINX,MAXX)
  27.          IF (MINY .GT. MAXY) CALL SWAP(MINY,MAXY)
  28.          CALL FG_SETCOLOR(RANDOM(0,15))
  29.          CALL FG_RECT(MINX,MAXX,MINY,MAXY)
  30. 10    CONTINUE
  31.  
  32.       CALL FG_SETMODE(OLD_MODE)
  33.       CALL FG_RESET
  34.  
  35.       STOP ' '
  36.       END
  37.  
  38.       INTEGER*2 FUNCTION RANDOM(MIN,MAX)
  39.  
  40.       INTEGER*2 MIN, MAX
  41.       INTEGER*2 SEED, TEMP
  42.  
  43.       DATA SEED /12345/
  44.  
  45.       TEMP = IEOR(SEED,ISHFT(SEED,-7))
  46.       SEED = IAND(IEOR(ISHFT(TEMP,8),TEMP),#7FFF)
  47.       RANDOM = MOD(SEED,MAX-MIN+1) + MIN
  48.  
  49.       RETURN
  50.       END
  51.  
  52.       SUBROUTINE SWAP(VAR1,VAR2)
  53.       INTEGER*2 VAR1, VAR2
  54.       INTEGER*2 TEMP
  55.  
  56.       TEMP = VAR1
  57.       VAR1 = VAR2
  58.       VAR2 = TEMP
  59.  
  60.       RETURN
  61.       END
  62.